Backdrop

프로그래머스 ▸ 코딩 기초 트레이닝

이어 붙인 수
0

문제 설명

정수가 담긴 리스트 num_list가 주어집니다. num_list의 홀수만 순서대로 이어 붙인 수와 짝수만 순서대로 이어 붙인 수의 합을 return하도록 solution 함수를 완성해주세요.

제한사항

  • 2 ≤ num_list의 길이 ≤ 10
  • 1 ≤ num_list의 원소 ≤ 9
  • num_list에는 적어도 한 개씩의 짝수와 홀수가 있습니다.

입출력 예

num_listresult
[3, 4, 5, 2, 1]393
[5, 7, 8, 3]581

입출력 예 설명

입출력 예 #1

  • 홀수만 이어 붙인 수는 351이고 짝수만 이어 붙인 수는 42입니다. 두 수의 합은 393입니다.

입출력 예 #2

  • 홀수만 이어 붙인 수는 573이고 짝수만 이어 붙인 수는 8입니다. 두 수의 합은 581입니다.

풀이

이론

Array.prototype.filter()

filter() 메서드는 주어진 함수의 테스트를 통과하는 모든 요소를 모아 새로운 배열로 반환해요.

filter(callbackFn[, thisArg])

callbackFn 함수는 세 가지 인자를 받아요.

  • element: 배열에서 처리되고 있는 현재 요소
  • index: 배열에서 처리되고 있는 현재 요소의 인덱스
  • array: filter를 호출한 배열
const words = [
  'spray',
  'limit',
  'elite',
  'exuberant',
  'destruction',
  'present',
];
const result = words.filter(word => word.length > 6);
 
console.log(result);
// Expected output: Array ["exuberant", "destruction", "present"]

코드

function solution(num_list) {
  const a = Number(num_list.filter(num => num % 2 === 1).join(''));
  const b = Number(num_list.filter(num => num % 2 === 0).join(''));
 
  return a + b;
}